package cn.itcast.xml.jsoup;

import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;

import java.io.File;
import java.io.IOException;

/*
    Element: 元素对象
							1.获取子元素对象
								getElementById(String id): 根据 id 属性值获取唯一的 element 对象
								getElementsByTag(String tagName): 根据标签名称获取元素对象集合
								getElementsByAttribute(String key): 根据属性名称获取元素对象集合
								getElementsByAttributeValue(String key, String value): 根据对应的属性名和属性值获取元素对象集合

							2.获取属性值
								String attr(String key): 根据属性名称获取属性值
							3.获取文本内容
								String text(): 获取文本内容
								String html(): 获取标签体的所有内容(包括字标签的标签和文本内容)
 */
public class JsoupDemo4 {
    public static void main(String[] args) throws IOException {
        //获取 student.xml 的 path
        String path = JsoupDemo4.class.getClassLoader().getResource("student.xml").getPath();

        //获取 Document 对象
        Document document = Jsoup.parse(new File(path), "utf-8");

        //通过 Document 对象获取 name 标签,获取所有的 name 标签
        Elements elements = document.getElementsByTag("name");
        System.out.println(elements.size());
        System.out.println("---------------");

        //通过 Element 对象获取子标签对象
        Element element_student = document.getElementsByTag("student").get(0);
        Elements ele_name = element_student.getElementsByTag("name");
        System.out.println(ele_name.size());
        System.out.println("---------------");

        //获取 student 对象属性
        String number = element_student.attr("number");
        System.out.println(number);
        System.out.println("--------------");

        //获取文本内容
        String text = ele_name.text();
        String html = ele_name.html();
        System.out.println(text);
        System.out.println(html);

    }
}
